import 'package:flutter/material.dart';
import 'package:enjoy_plus_three/utils/event_bus.dart';
import 'package:enjoy_plus_three/utils/http.dart';
import 'package:enjoy_plus_three/utils/logger.dart';
import 'package:enjoy_plus_three/utils/toast.dart';
import 'package:enjoy_plus_three/utils/token.dart';

import '../tab_bar_page.dart';

class MinePage extends StatefulWidget {
  MinePage({super.key, required this.currentIndex});
  int currentIndex;

  @override
  State<MinePage> createState() => _MinePageState();
}

class _MinePageState extends State<MinePage> {
  // 菜单数据
  final List menuList = [
    {
      "title": "我的房屋",
      "icon": "assets/images/house_profile_icon@2x.png",
    },
    {
      "title": "我的报修",
      "icon": "assets/images/repair_profile_icon@2x.png",
    },
    {
      "title": "访客记录",
      "icon": "assets/images/visitor_profile_icon@2x.png",
    }
  ];

  // 用户信息
  Map userInfo = {'id': '', 'avatar': null, 'nickName': null};

  // 测试token - 获取房屋
  _getHouse() async {
    final res = await http.get('/house');
    logger.i(res);
  }

  _getProfile() async {
    final res = await http.get('/userInfo');
    if (res['code'] != 10000) return ToastUtil.showError('用户信息获取失败');
    setState(() {
      userInfo = res['data'];
    });
  }

  @override
  void initState() {
    super.initState();
    // 订阅 登录页 发布的重新获取用户信息的事件
    eventBus.on<RefreshMine>().listen((event) {
      _getProfile();
    });
  }

  // didUpdateWidget 组件重建时会触发
  // 该钩子函数内 状态变量发生变化时, 会触发
  @override
  void didUpdateWidget(covariant MinePage oldWidget) {
    // widget.xxx 获取父组件的数据
    if (widget.currentIndex == 1) {
      // 获取用户资料
      _getProfile();
    }
    super.didUpdateWidget(oldWidget);
  }

  @override
  Widget build(BuildContext context) {
    return Scaffold(
      backgroundColor: const Color.fromARGB(200, 85, 145, 175),
      appBar: AppBar(
        title: const Text('我的', style: TextStyle(color: Colors.white)),
        backgroundColor: Colors.transparent,
        centerTitle: true,
      ),
      body: ListView(
        children: [
          // 个人信息
          Container(
              padding: const EdgeInsets.all(10),
              child: GestureDetector(
                  onTap: () {
                    Navigator.pushNamed(context, '/profile',
                        arguments: userInfo);
                  },
                  child: Row(children: [
                    Row(children: [
                      ClipRRect(
                          borderRadius: BorderRadius.circular(50.0),
                          child: userInfo['avatar'] != null
                              ? Image.network(userInfo['avatar'],
                                  width: 50, height: 50)
                              : Image.asset('assets/images/avatar_1.jpg',
                                  width: 50, height: 50)),
                      const SizedBox(width: 10),
                      Text(userInfo['nickName'] ?? '用户名',
                          style: const TextStyle(
                              fontSize: 16, color: Colors.white))
                    ]),
                    const Spacer(),
                    const Row(children: [
                      Text(
                        '去完善信息',
                        style: TextStyle(color: Colors.white),
                      ),
                      Icon(
                        Icons.arrow_forward_ios,
                        color: Colors.white,
                        size: 13,
                      )
                    ])
                  ]))),
          Container(
              padding: const EdgeInsets.all(15),
              margin: const EdgeInsets.only(
                  top: 20, left: 10, right: 10, bottom: 20),
              decoration: BoxDecoration(
                  color: Colors.white, borderRadius: BorderRadius.circular(10)),
              child: Column(
                children: menuList.map((item) {
                  return SizedBox(
                      height: 50,
                      child: Row(children: [
                        Row(
                          children: [
                            Image.asset(
                              item['icon'],
                              width: 20,
                              height: 20,
                            ),
                            const SizedBox(
                              width: 10,
                            ),
                            Text(
                              item['title'],
                              style: const TextStyle(fontSize: 16),
                            )
                          ],
                        ),
                        const Spacer(),
                        const Icon(
                          Icons.arrow_forward_ios,
                          size: 12,
                          color: Colors.grey,
                        ),
                      ]));
                }).toList(),
              )),
          Container(
            padding: const EdgeInsets.only(left: 15),
            child: Row(
              children: [
                ElevatedButton(
                    onPressed: () {
                      _getHouse();
                    },
                    child: const Text('测试token失效')),
                const SizedBox(width: 10),
              ],
            ),
          )
        ],
      ),
    );
  }
}
